@forward "variables";
@forward "namespace"; // 导出到项目的全局变量里，当前文件无法使用 namespace.scss 的变量
@use "transition";
@use "element-plus/theme-chalk/dark/css-vars.css"; // Element Plus 内置暗黑模式
@use "element-dark"; // 自定义暗黑模式
@use "namespace" as *; // 当前文件使用 namespace.scss 的变量

// 自定义 EP 样式命名空间
@forward "element-plus/theme-chalk/src/mixins/config.scss" with (
  $namespace: #{$el-namespace}
);

/* Global scss */
body {
  height: 100%;
  margin: 0 !important;
  overflow: hidden;
  font-family: -apple-system, BlinkMacSystemFont, "PingFang SC", "Segoe UI", "Helvetica Neue", Helvetica,
    "Hiragino Sans GB", "Microsoft YaHei", Arial, sans-serif;
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
}

html {
  height: 100%;
}

#app {
  height: 100%;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

a,
a:focus,
a:hover {
  color: inherit;
  text-decoration: none;
  outline: none;
}

div:focus {
  outline: none;
}

.clearfix {
  &::after {
    display: table;
    clear: both;
    content: "";
  }
}

.text-center {
  text-align: center;
}

.no-padding {
  padding: 0 !important;
}

/* flex */
.flx-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.flx-justify-between {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.flx-align-center {
  display: flex;
  align-items: center;
}

/* clearfix */
.clearfix-after {
  display: block;
  height: 0;
  overflow: hidden;
  clear: both;
  content: "";
}

/* 文字单行省略号 */
.sle {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* 文字多行省略号 */
.mle {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

/* 文字多了自動換行 */
.break-word {
  word-break: break-all;
  word-wrap: break-word;
}

/* scroll bar */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-thumb {
  background-color: #d3d3d3;
  border-radius: 20px;
  box-shadow: inset 0 0 0 white;
}

/* nprogress 样式 */
#nprogress .bar {
  background: var(--#{$el-namespace}-color-primary) !important;
}

#nprogress .spinner-icon {
  border-top-color: var(--#{$el-namespace}-color-primary) !important;
  border-left-color: var(--#{$el-namespace}-color-primary) !important;
}

#nprogress .peg {
  box-shadow:
    0 0 10px var(--#{$el-namespace}-color-primary),
    0 0 5px var(--#{$el-namespace}-color-primary) !important;
}

/* 当前页面最大化 css */
.main-maximize {
  .aside-split,
  .#{$el-namespace}-aside,
  .#{$el-namespace}-header,
  .#{$el-namespace}-footer,
  .tabs-nav {
    display: none !important;
  }
}

/* 克隆并自定义 ElMessage 样式，不会影响 ElMessage 原本样式，在 src/utils/message.ts 中调用自定义样式 ElMessage 方法即可，暗黑模式在 src/style/dark.scss 文件进行了适配 */
.antd-message {
  padding: 10px 13px !important;
  background: #ffffff !important;
  border-width: 0 !important;
  box-shadow:
    0 3px 6px -4px #0000001f,
    0 6px 16px #00000014,
    0 9px 28px 8px #0000000d !important;

  &.#{$el-namespace}-message.is-closable .#{$el-namespace}-message__content {
    padding-right: 17px !important;
  }

  & .#{$el-namespace}-message__content {
    color: #000000d9 !important;
    pointer-events: all !important;
    background-image: initial !important;
  }

  & .#{$el-namespace}-message__icon {
    margin-right: 8px !important;
  }

  & .#{$el-namespace}-message__closeBtn {
    right: 9px !important;
    border-radius: 4px;
    outline: none;
    transition:
      background-color 0.2s,
      color 0.2s;

    &:hover {
      background-color: rgb(0 0 0 / 6%);
    }
  }
}

/* 自定义 card 卡片样式 */
.card {
  box-sizing: border-box;
  padding: 20px;
  overflow-x: hidden;
  background-color: var(--#{$el-namespace}-fill-color-blank);
  border: 1px solid var(--#{$el-namespace}-border-color-light);
  border-radius: 4px;
  box-shadow: 0 0 12px rgb(0 0 0 / 5%);
}

/* 主题色悬停样式 */
.theme-color-hover:hover {
  color: var(--#{$el-namespace}-color-primary);
}

/* 自定义 el-drawer 样式 */
.#{$el-namespace}-drawer {
  .#{$el-namespace}-drawer__header {
    padding: 15px 20px 14px;
    margin-bottom: 0;
    border-bottom: 1px solid var(--#{$el-namespace}-border-color-lighter);

    // 统一 Dialog、Drawer 字体大小可以打开
    // span {
    //   font-size: 17px;
    //   color: var(--#{$el-namespace}-text-color-primary) !important;
    // }
  }

  .#{$el-namespace}-drawer__footer {
    border-top: 1px solid var(--#{$el-namespace}-border-color-lighter);
  }

  /* drawer select 样式 */
  .#{$el-namespace}-select {
    width: 100%;
  }

  /* drawer-form 中存在两列 form-item */
  .drawer-multiColumn-form {
    display: flex;
    flex-wrap: wrap;

    .#{$el-namespace}-form-item {
      width: 47%;

      &:nth-child(2n-1) {
        margin-right: 5%;
      }
    }
  }
}

/* 自定义 el-dialog 样式 */
.#{$el-namespace}-dialog {
  .#{$el-namespace}-dialog__header {
    border-bottom: 1px solid var(--#{$el-namespace}-border-color-lighter);

    // 统一 Dialog、Drawer 字体大小可以打开
    // span {
    //   font-size: 17px;
    //   color: var(--#{$el-namespace}-text-color-primary) !important;
    // }
  }

  .#{$el-namespace}-dialog__body {
    padding-top: 15px;
  }

  .#{$el-namespace}-dialog__footer {
    border-top: 1px solid var(--#{$el-namespace}-border-color-lighter);
  }
}

/* 自定义原子类 */
@for $i from 1 through 6 {
  .m-#{$i * 5} {
    margin: ($i * 5) + px;
  }
  .mt-#{$i * 5} {
    margin-top: ($i * 5) + px;
  }
  .mb-#{$i * 5} {
    margin-bottom: ($i * 5) + px;
  }
  .ml-#{$i * 5} {
    margin-left: ($i * 5) + px;
  }
  .mr-#{$i * 5} {
    margin-right: ($i * 5) + px;
  }

  .p-#{$i * 5} {
    padding: ($i * 5) + px;
  }
  .pt-#{$i * 5} {
    padding-top: ($i * 5) + px;
  }
  .pb-#{$i * 5} {
    padding-bottom: ($i * 5) + px;
  }
  .pl-#{$i * 5} {
    padding-left: ($i * 5) + px;
  }
  .pr-#{$i * 5} {
    padding-right: ($i * 5) + px;
  }
}

@for $i from 14 through 24 {
  .fz-#{$i} {
    font-size: ($i) + px;
  }
}
